//#include<iostream>
//using namespace std;
//int d[500000]={0};
//int mins=101;
//int fun(int a,int b,int z){
//	for(int i=a-1;i<b;i++){
//		d[i]+=z;
//	}
//}
//int main(){
//	int n,m;
//	cin>>n>>m;
//	for(int i=0;i<n;i++){
//		cin>>d[i];
//	}
//	int a,b,z;
//	for(int i=0;i<m;i++){
//		cin>>a>>b>>z;
//		fun(a,b,z);
//	}
//	for(int i=0;i<n;i++){
//		if(mins>d[i])
//			mins=d[i];
//	}
//	cout<<mins;
//}
#include<iostream>
using namespace std;
short int d[500001];
short int de[500001];
int main(){
	int m,n;
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		cin>>d[i];
		de[i]=d[i]-d[i-1];
	}
	int x,y,z;
	for(int j=1;j<=m;j++){
		cin>>x>>y>>z;
		de[x]+=z;
		de[y+1]-=z;
	}
	int mins=101;
	for(int i=1;i<=n;i++){
		d[i]=de[i]+d[i-1];
		if(d[i]<mins)
		mins=d[i];
	}
	cout<<mins;
} 
